Pagination এবং Sorting এর ধারণা

Java Technologies - স্প্রিং বুট জেপিএ (Spring Boot JPA) - Pagination এবং Sorting
337

Pagination এবং Sorting হল Spring Data JPA-এর দুটি অত্যন্ত গুরুত্বপূর্ণ বৈশিষ্ট্য যা ডেটাবেস থেকে ডেটা রিট্রিভ করার সময় কার্যকারিতা এবং পারফরম্যান্স বৃদ্ধি করতে সাহায্য করে। বড় ডেটাসেটের সাথে কাজ করার সময় Pagination এবং Sorting এর মাধ্যমে আপনি ডেটা সঠিকভাবে এবং কার্যকরীভাবে ম্যানেজ করতে পারবেন।

1. Pagination (পেজিনেশন)

Pagination হল একটি কৌশল যা ডেটাবেসের বৃহত পরিমাণ ডেটাকে ছোট ছোট পৃষ্ঠায় ভাগ করে রিট্রিভ করে। এর মাধ্যমে আপনি নির্দিষ্ট সংখ্যা ডেটা (যেমন প্রতি পৃষ্ঠায় ২০টি আইটেম) একে একে লোড করতে পারেন, যা অ্যাপ্লিকেশনকে দ্রুত এবং আরও দক্ষ করে তোলে।

Spring Data JPA তে Pagination কার্যকরভাবে ব্যবহৃত হয় Pageable ইন্টারফেসের মাধ্যমে। Pagination ব্যবহার করলে, আপনি Page অবজেক্ট পান, যা ডেটার পরিমাণ, মোট পৃষ্ঠা এবং অন্যান্য পেজিনেশন সম্পর্কিত তথ্য ধারণ করে।

Pagination এর সুবিধা:

  • Efficient data retrieval: বৃহত ডেটাসেট রিট্রিভ করার জন্য পেজিনেশন ডেটার লোডিং দ্রুত এবং কার্যকর করে।
  • Reduces Memory Usage: একসাথে সমস্ত ডেটা লোড না করে, পেজিনেশন শুধুমাত্র প্রয়োজনীয় ডেটাই লোড করে, ফলে মেমরি ব্যবহার কম হয়।

উদাহরণ:

Step 1: Entity Class

@Entity
public class Product {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private Double price;

    // Getters and Setters
}

Step 2: Repository Interface

import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;

public interface ProductRepository extends JpaRepository<Product, Long> {
    // Pagination with Pageable parameter
    Page<Product> findAll(Pageable pageable);
}

Step 3: Service Class

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.stereotype.Service;

@Service
public class ProductService {

    @Autowired
    private ProductRepository productRepository;

    public Page<Product> getPaginatedProducts(int page, int size) {
        // Creating Pageable object with page number and page size
        Pageable pageable = PageRequest.of(page, size);
        return productRepository.findAll(pageable);
    }
}

Step 4: Controller Class

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class ProductController {

    @Autowired
    private ProductService productService;

    @GetMapping("/products")
    public Page<Product> getPaginatedProducts(@RequestParam int page, @RequestParam int size) {
        return productService.getPaginatedProducts(page, size);
    }
}

এই উদাহরণে, PageRequest.of(page, size) ব্যবহার করা হয়েছে, যেখানে page হল পৃষ্ঠা নম্বর এবং size হল প্রতিটি পৃষ্ঠায় কতটি আইটেম দেখতে চান।


2. Sorting (সোর্টিং)

Sorting হল একটি প্রক্রিয়া যা ডেটাকে নির্দিষ্ট একটি ক্রমে সাজাতে সাহায্য করে (যেমন ascending বা descending) কোনও নির্দিষ্ট ক্ষেত্রের (column) ভিত্তিতে। Spring Data JPA তে Sorting করার জন্য Sort ক্লাস ব্যবহার করা হয়। Sorting ব্যবহার করলে ডেটা সাধারণত একটি নির্দিষ্ট ফিল্ড বা কলাম অনুযায়ী সাজানো হয়।

Sorting এর সুবিধা:

  • Organized Data: সঠিক ক্রমে ডেটা সাজানো ডেটা বিশ্লেষণ এবং ব্যবহারকে সহজ করে।
  • Improves User Experience: ইউজাররা যখন ডেটা সঠিকভাবে সাজানো অবস্থায় দেখতে পায়, তখন অ্যাপ্লিকেশনের ইউজার এক্সপেরিয়েন্স বৃদ্ধি পায়।

উদাহরণ:

Step 1: Entity Class

@Entity
public class Product {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private Double price;

    // Getters and Setters
}

Step 2: Repository Interface with Sorting

import org.springframework.data.domain.Sort;
import org.springframework.data.jpa.repository.JpaRepository;
import java.util.List;

public interface ProductRepository extends JpaRepository<Product, Long> {
    List<Product> findAll(Sort sort);
}

Step 3: Service Class

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Sort;
import org.springframework.stereotype.Service;

@Service
public class ProductService {

    @Autowired
    private ProductRepository productRepository;

    public List<Product> getSortedProducts(String sortBy, boolean ascending) {
        Sort sort = ascending ? Sort.by(sortBy).ascending() : Sort.by(sortBy).descending();
        return productRepository.findAll(sort);
    }
}

Step 4: Controller Class

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class ProductController {

    @Autowired
    private ProductService productService;

    @GetMapping("/products/sorted")
    public List<Product> getSortedProducts(@RequestParam String sortBy, @RequestParam boolean ascending) {
        return productService.getSortedProducts(sortBy, ascending);
    }
}

এখানে, Sort.by(sortBy) ব্যবহার করে ডেটা ascending বা descending অর্ডারে সাজানো হচ্ছে, এবং sortBy প্যারামিটার অনুযায়ী কোন ফিল্ড দ্বারা সোর্ট করা হবে তা নির্ধারণ করা হচ্ছে।


Pagination এবং Sorting একসাথে ব্যবহার

Spring Data JPA তে Pagination এবং Sorting একসাথে ব্যবহার করা যায়। যখন আপনি ডেটাকে পেজিনেট করবেন এবং সেই সাথে সোর্টিংও করবেন, তখন PageRequest এবং Sort একসাথে ব্যবহার করা হয়।

উদাহরণ:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.stereotype.Service;

@Service
public class ProductService {

    @Autowired
    private ProductRepository productRepository;

    public Page<Product> getSortedPaginatedProducts(int page, int size, String sortBy, boolean ascending) {
        Sort sort = ascending ? Sort.by(sortBy).ascending() : Sort.by(sortBy).descending();
        PageRequest pageRequest = PageRequest.of(page, size, sort);
        return productRepository.findAll(pageRequest);
    }
}

Controller:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class ProductController {

    @Autowired
    private ProductService productService;

    @GetMapping("/products/sortedPaginated")
    public Page<Product> getSortedPaginatedProducts(@RequestParam int page, @RequestParam int size, @RequestParam String sortBy, @RequestParam boolean ascending) {
        return productService.getSortedPaginatedProducts(page, size, sortBy, ascending);
    }
}

এখানে, PageRequest.of(page, size, sort) ব্যবহার করে ডেটা পেজিনেট করা হচ্ছে এবং সেই সাথে সঠিক ক্রমে সাজানো হচ্ছে।


সারাংশ

Pagination এবং Sorting হল Spring Data JPA-তে গুরুত্বপূর্ণ বৈশিষ্ট্য যা বড় ডেটাসেট ম্যানেজমেন্টে কার্যকারিতা এবং স্কেলেবিলিটি বৃদ্ধি করে। Pagination ডেটাকে ছোট ছোট পৃষ্ঠায় ভাগ করে, এবং Sorting ডেটাকে সঠিক ক্রমে সাজিয়ে ডেটাবেস অপারেশনগুলিকে আরও দ্রুত এবং কার্যকর করে তোলে। Pageable এবং Sort ক্লাস ব্যবহার করে Spring Data JPA এ সহজে Pagination এবং Sorting কার্যকরভাবে পরিচালনা করা সম্ভব।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...